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(m) Data processing system. 

@ Described is a data processing system in 
which different kinds of system environments 
can be implemented concurrently to allow ap- 
plication programs for different kinds of sys- 
tems to run concurrently within a single system. 
The data processing system includes emulation 
means for emulating concurrently each of the 
different kinds of system environments to a 
system control program (operating system). 
This facilitates the sharing of resources or com- 
munication between the application programs. 
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The present invention relates to a data process- 
ing system in which plural application programs cre- 
ated for different kinds of system environments can 
be run concurrently. 

It is advantageous to run plural application pro- 
grams created for different kinds of system environ- 
ments concurrently on a single system. For example, 
an operating system called DOS (Disk Operating Sys- 
tem) is widely used as an operating system for per- 
sonal computers. However, even if DOS is installed in 
two personal computers, their system environments 
may be different from one another. The environments 
may be different first for the reason that there are dif- 
ferent kinds of DOS itself and second for the reason 
that application programs for DOS frequently access 
BIOS (basic input/output system) or hardware directly 
and therefore DOS cannot cover up differences in the 
types of hardware. 

The ability to run plural application programs cre- 
ated for different kinds of system environments on a 
single system is known. However, these prior sys- 
tems are arranged such that multiple kinds of OSs 
(Operating systems) are retained in a hard disk, etc. 
and any of the OSs is selectively installed, at a time 
of system reset, etc., in a system memory. Therefore, 
according to the prior art, only one system environ- 
ment can exist at any one time, which prevents the 
sharing of resources or communication between the 
plural application programs. 

The present invention seeks to implement differ- 
ent kinds of system environments concurrently on a 
single system and allow application programs for dif- 
ferent kinds of systems to run concurrently on a sin- 
gle system. 

Accordingly, the invention provides a data proc- 
essing system adapted to run application programs in 
different kinds of system environments concurrently, 
comprising: 

a microprocessor for executing said programs; 
a system memory for storing said programs; 

and 

a system control program including emulation 
means for emulating each of the different kinds of 
system environments concurrently in the system ac- 
cording to data associated with each application pro- 
gram which defines the system environment to be 
emulated for that application program. 

A preferred embodiment of the invention will now 
be described, by way of example only, with reference 
to the accompanying drawings in which: 

FIG.1 is a block diagram shoving the configura- 
tion of an embodiment of an operating system accord- 
ing to the present invention. 

FIG. 2 is a block diagram showing the configura- 
tion of a virtual device driver of said embodiment 

FIG.3 is a block diagram showing the configura- 
tion of a logic memory of said embodiment. 

FIG. 4. is a block diagram showing the configura- 



tion of an embodiment of an information processing 
system according to the present invention. 

FIG.5 is a front view showing the configuration of 
a menu screen for setting properties of said embodt- 
5 ment. 

FIG. 4 shows an embodiment of an information 
processing system according to the present inven- 
tion. In the figure, an information processing system 
1 includes a microprocessor (CPU) 2 for execution of 

10 a program, a system memory 3 for storing said pro- 
gram, an input device group 4 for inputting instruc- 
tions or data required for the execution of said pro- 
gram, and an output device group 5 such as a display 
unit, etc. for outputting a result of the execution of said 

is program. Said program includes a system control pro- 
gram (operating system) 10, a basic input/output sys- 
tem (physical BIOS, or PBIOS) 15 retained in a ROM, 
etc., and N application programs (20-1 to 20- n). 
These application programs 20-1 to 20-n are applica- 

20 tton programs developed for different kinds of system 
environments. 

As used in the present description 'system* re- 
fers to an information processing apparatus into 
which an operating system is installed, and includes 

25 a BIOS retained in a ROM which is usually provided 
in the information processing apparatus. Examples of 
different kinds of systems are the IBM PS/2 personal 
computer (PS/2 is a trademark of International Busi- 
ness Machines Corporation) into which a PC- DOS is 

30 installed and the IBM PS/55 personal computer 
(PS/55 is a trademark of International Business Ma- 
chines Corporation) into which Japanese DOS is in- 
stalled. An OADG (Open Architecture Developer 
Group) personal computer into which DOS/V is instal- 

35 led is another example of such a system. PC- DOS is 
commonly used as a standard operating system for 
personal computers in U.S., while Japanese DOS is 
an operating system, with Japanese support func- 
tions added to the PC-DOS, adapted for use in Japan. 

40 DOS/V is a operating system capable of handling Jap- 
anese using a standard video adapter card, which is 
called VGA (Video Graphics Array), used in the U.S. 
and OADG (Open Architecture Developers Group) is 
a group of companies which develop personal com- 

45 puters with functions capable of handling Japanese, 
a standard operating system of which is the DOS/V. 
Hereinafter, an individual system environment provid- 
ed to each of the application programs 20-1, 20-n to 
be run concurrently is called a virtual DOS machine 

50 (VDM). 

The PS/2 keyboard is designed primarily for 
users of the English language while the PS/55 key- 
board is designed for users of Japanese. The PS/2 
and the PS/55 personal computers are also different 

55 from each other also in the resolution of the display 
unit, access method, I/O functions and also in the 
BlOSs provided to them. For example, a function not 
provided to a BIOS for the PS/2 is provided to a BIOS 
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for the PS/55 or the same interface (INT xxH) be- 
comes a request for different function between the 
BIOS for the PS/2 and the BIOS for the PS/55. Now 
it is assumed that one of the N application programs 
(20-1 to 20-n) is an application program 20-a for the 
PC-DOS, another one of them is an application pro- 
gram 20-b for the Japanese DOS, and a still another 
one of them is an application program 20-c for the 
DOS/V. The CPU 2 is a microprocessor whose trade 
name is, for example, the Intel 80386 or 80486 and 
the first application programs (20-1 to 20-n) are run 
concurrently under a virtual 86(V86) mode provided 
to the microprocessor on the system 1. The term 
"concurrently 0 means that "timesharing multitasking" 
operations are performed. 

FIG.1 shows the configuration of the operating 
system 10 according to the present invention. The op- 
erating system 1 0 operates in the virtual 86 mode and 
a 386 mode of the CPU 2. In the figure, the applica- 
tion program 20-a for PC-DOS, the application pro- 
gram 20-b for Japanese DOS, and the application 
program 20-c for DOS/V run under the virtual 86 
mode of the CPU. The application program 20-a for 
PC-DOS issues a system call (for example, INT 
20H/21 H/25H/26H) to the PC-DOS, a BIOS call (for 
example, INT 1 0H/11 H/12H/13H/14H/15H/16H/17H/ 
18H/19H/1AH/1FH) to a BIOS installed in such per- 
sonal computers as the PS/2, etc., and a direct in- 
put/output instruction (IN IO address/OUT IO ad- 
dress) for the hardware of the PS/2, etc. The applica- 
tion program 20-b for Japanese DOS issues a system 
call (for example, INT 20H/21H/25H/26H) to the Jap- 
anese DOS, a BIOS call (for example, INT 10H/11H/ 
1 2H/13H/14H/1 5H/16H/1 7H/1 8H/1 9H/1 AH/1 FH/7DH) 
to a BIOS installed in such personal computers as the 
PS/55, etc., and a direct input/output instruction (IN 
IO address/OUT IO address) for the hardware of the 
PS/55, etc. A system call, a BIOS call, and a direct I/O 
instruction for the hardware issued by the application 
program 20-c for DOS/V have a different part from 
some ones of the above two application programs 20- 
a and 20-b. 

The Japanese DOS has Japanese support func- 
tions added to the PC-DOS. However, the Japanese 
DOS and the PC-DOS differ somewhat in parts other 
than the Japanese support functions. Further the 
DOS/V differs somewhat from the Japanese DOS or 
the PC-DOS. A system call issued by the application 
programs 20-a, 20-b, and 20c is provided to a DOS 
kernel emulator 34 which operates in the virtual 86 
mode, and on the other hand a BIOS call and a direct 
I/O instruction for the hardware issued by the appli- 
cation programs 20-a, 20-b, and 20-c are provided to 
a virtual device driver group 36 which operates in the 
386 mode. The DOS kernel emulator 34 emulates a 
system call, requests further processing by the virtual 
device driver group 36, as required, or issues a sys- 
tem call to an OS/2 kernel 44 which operates in the 



386 mode in the cases of system calls as file open, 
file read/ write, etc. so that a system call issued by the 
application programs 20-a, 20-b, and 20-c can be 
executed. 

5 A system environment provided, by the virtual de- 

vice driver group 36, to the application programs 20- 
a, 20-b, and 20-c is determined according to the con- 
tents of setting of a property 41. Applications 4 0-a and 
40-bfor OS/2 are application programs that run in the 

10 386 mode of the CPU 2. These application programs 
access, through a subsystem 42, to a hardware group 
or, through the OS/2 kernel 44, to a physical device 
driver 46. The physical device driver 46 accesses the 
hardware group either directly or via BIOS 15. 

15 Fig.2 shows the details of the virtual device driver 

group 36. The virtual device driver group 36 has a role 
of implementation of virtual access to BIOS or the 
hardware from the application programs 20-a, 20-b, 
and 20-c. The virtual device driver group 36 compris- 

20 es a virtual BIOS 71, a virtual Kana-to-Kanji convert 
device driver 72, a virtual mouse device driver 73, a 
virtual communication device driver 74, a virtual disk 
device driver 75, a virtual printer device driver 76, a 
virtual keyboard device driver 77, and a virtual video 

25 device driver 78. 

The function of the virtual BIOS 71 is to selective- 
ly provide one of three BIOS environments to each of 
the application programs 20-a, 20-b, and 20-c. The 
three BIOS environments mentioned above mean an 

30 emulator of a BIOS (US-BIOS) for PS/2, an emulator 
of a BIOS (Japanese BIOS) for PS/55, and an emu- 
lator of a BIOS for DOSA/. The user can select one of 
the three BIOS environments for each VDM using the 
property 41. The function of the property 41 is to allow 

35 a DOS environment or a BIOS environment to be set 
for each VDM and the property 41 is a system data 
area for describing the DOS environment or the BIOS 
environment for each VDM. The virtual BIOS 71, the 
virtual device driver 72, etc. determine the type of 

40 emulation according to the contents of description in 
the property 41 . The virtual BIOS 71 is loaded into the 
system memory 3 and initialized earlier than other 
virtual device drivers 72 and others. The virtual BIOS 
71 provides flags indicating the data areas of the US- 

45 BIOS, the Japanese BIOS, and the BIOS for DOSA/ 
and a BIOS mode. 

As shown in FIG.3, the virtual BIOS 71 provides 
a predetermined capacity (for example, 1 M bytes) of 
memory space for each VDM as a work area for an 

so application program for DOS. The work area is used 
under the virtual 86 mode of the CPU 2. A system call, 
a BIOS call, or a direct access request for the hard- 
ware issued by the application program for DOS 
switches an operation mode to the 386 mode. In this 

55 case, reference to a property is made and the con- 
tents of the property deter mines_which system envir- 
onment is provided by the operation of the virtual de- 
vice driver group 36. The device driver group 36 is 
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provided in a system area, and logically provided for 
each application program for DOS, but physically 
shared, through the use of a paging function, be- 
tween the application programs for DOS. The remain- 
ing areas of the system memory 3 are assigned to 
programs for supporting fundamental functions of the 
operating system 10 of the embodiment 

To run plural application programs for DOS con- 
currently, it is necessary that the operating system 
10 manages access to the resources of the informa- 
tion processing system 1 from the application pro- 
grams. Such resources as the input device group 4 
and the output device group 5 must be assigned to an 
application program in a foreground. On the other 
hand, virtual resources must be assigned to an appli- 
cation program in a background. The virtual device 
driver group 36 creates virtual resources, which are 
assigned to an application programs in the back- 
ground. For example, the virtual video device driver 
78 has a virtual video buffer corresponding to a spe- 
cified system environment in a predetermined area of 
the system memory 3. The application program in the 
background accesses the virtual video buffer as if it 
is a physical video buffer. Data written in the virtual 
video buffer is expanded, when the application pro- 
gram in the background is switched from background 
to foreground, into the physical video buffer. 

When the operating system 10 is loaded into the 
system memory 3, a menu is displayed on the screen 
of an output device. The user can select a system en- 
vironment through the menu. The menu can be called 
whenever the system is operating. Once the menu is 
called, the user can create a new system environment 
or switch to a system environment previously created 
under an operation. In the following, an example of 
the operating procedures of the user is described. 
Operating procedure 1: Creates a system envir- 
onment for PS/2 through the menu. 
Operating procedure 2: Initiates an application 
program for PS-DOS. 
Operating procedure 3: Calls the menu. 
Operating procedure 4: Creates a system envir- 
onment for PS/55 through the menu. 
Operating procedure 5: Initiates an application 
program for Japanese DOS. 
Operating procedure 6: Calls the menu. 
Operating procedure 7: Creates a second system 
environment for PS/2 through the menu. 
Operating procedure 8: Calls the menu. 
Operating procedure 9: Switches to the first sys- 
tem environment for PS/2 through the menu. 
FIG.5 shows an example of the contents of a 
menu to be displayed. The user sets, through such a 
menu, the contents of a property. In the example of 
FIG.5, the user can select a BIOS type for a system 
environments to be established from US-BIOS (BIOS 
for PS/2), Japanese BIOS (BIOS for PS/55), and 
BIOS for DOS/V. If the Japanese BIOS or the BIOS 



for DOS/V is selected, either a DOS KCC mode or a 
both use mode can be selected. The DOS KCC mode 
is a Kana-to-Kanji conversion mode for using a DOS- 
dedicated Kana-to-Kanji converting frontend proces- 
5 sor, and on the other hand a both use mode is a Kana- 
to-Kanji conversion mode for using together Kana-to- 
Kanji conversion provided by the operating system 
10. 

As described above, if a BIOS type is specified for 

10 a property, the virtual device driver group 36 estab- 
lishes a virtual system environment, based on the 
BIOS type specified, as any one for PS/2, PS/55, or 
DOS/V. If the US-BIOS is specified, in order to estab- 
lish a virtual system environment for emulating the 

15 PS/2 , the virtual device driver group 36 configured 
so that an English environment and an interface to a 
BIOS for the PS/2, and the hardware of the PS/2 are 
supported, is provided to a VDM. If the Japanese 
BIOS is specified, in order to establish a virtual sys- 

20 tern environment for emulating the PS/55, the virtual 
device driver group 36 configured so that a Japanese 
environment and an interface to a BIOS for the PS/55, 
and the hardware of the PS/55 are supported, is pro- 
vided to a VDM. If the BIOS for DOS/V is specified, 

25 in order to establish a virtual system environment for 
emulating the OADG persona! computer, the virtual 
device driver group 36 configured so that a Japanese 
environment and an interface to a BIOS for the OADG 
personal computer, and the hardware of the OADG 

30 personal computer are supported, is provided to a 
VDM. 

When a VDM is created, the virtual device driver 
group 36 initializes system parameters incidental to 
hardware according to the specification of a property. 

35 For example, the virtual video device driver 78, sets 
initial parameters, according to the specification of a 
property, to a video adapter (display adapter) for the 
PS/2, a video adapter for PS/55, or a video adapter for 
the OADG personal computer. Further, it assigns vir- 

40 tual display buffer for an application program in the 
background. Still further, it provides a virtual I/O ad- 
dress of a video adapter. For example, the virtual key- 
board device driver 77 provides a scan code conver- 
sion table, according to the specification of a proper- 

45 ty, for the PS/2, the PS/55, or the OADG personal 
computer. For the Japanese system environment, in 
addition to the above, it establishes an interface to 
the Kana-to-Kanji conversion program. Additionally, 
the virtual device driver group 36 initializes parame- 

50 ters for the related BIOSs. 

By means of the virtual device driver group 36, a 
virtual system environment is provided for each appli- 
cation program as follows. That "is, provided for an ap- 
plication program for PC-DOS are the English envir- 

55 onment, the BIOS interface for PS/2, and the hard- 
ware environment or PS/2 (video adapter emulation, 
keyboard adapter emulation, scan code conversion 
table, printer data stream emulation, etc.). Provided 
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for an application program for Japanese DOS are the 
Japanese environment, the BIOS interface for PS/55, 
and the hardware environment of PS/55 (video adap- 
ter emulation, keyboard adapter emulation, scan 
code conversion table, printer data stream emulation , 5 
etc.). Provided for an application program for DOS/V 
are the Japanese environment, the BIOS interface for 
the OADG personal computer, and the hardware en- 
vironment of the hardware of OADG personal com- 
puter (video adapter emulation, keyboard adapter 10 
emulation, scan code conversion table, printer data 
stream emulation, etc.). 

The above different kinds of system environ- 
ments are run concurrently under the operating sys- 
tem 10. which is a multi-tasking operating system. An 15 
operation (not key operation) by the user or a pro- 
gramming interface causes the foreground and the 
background to be switched to each other. In such 
switching, the virtual device driver group 36 switches 
physical hardware and virtual hardware to each other. 20 

As described above, according to the embodi- 
ment, application programs for different kinds of 
DOSs can run concurrently on a single personal com- 
puter. Further, plural language environments being 
provided al the same time, for example, English, Jap- 25 
anese, and Korean application program can run con- 
currently. Still further, application programs for differ- 
ent kinds of DOSs running concurrently, the func- 
tions of each application program can be shared 
among the application programs. For example, rf it is 30 
assumed that a communication program can run only 
under the PC-DOS and a wordprocessor program can 
run only under the Japanese DOS, then, according to 
the embodiment, the communication program can re- 
ceive data and the wordprocessor program can edit 35 
the data. Further, application programs for different 
kinds of DOSs running concurrently, the sharing of 
system resources is promoted, and therefore, for ex- 
ample, the screen information of a VDM for PC-DOS 
can be inputted as the key information of a VDM for 40 
Japanese DOS. 

It will be appreciated that the embodiment is ap- 
plied not only to three different kinds of system envir- 
onments, but also to plural different kinds of system 
environments other than the three different kinds of 45 
system environments. It will be appreciated also that 
a virtual system environment is not limited to the em- 
bodiment described above. 



Claims 

1. A data processing system (1) adapted to run ap- 
plication programs in different kinds of system 
environments concurrently, comprising: 55 

a microprocessor (2) for executing said 
programs; 

a system memory (3) for storing said pro- 




610 A2 3 

grams; and 

emulation means for emulating each of 
the different kinds of system environments con- 
currently in the system according to data associ- 
ated with each application program which de- 
fines the system environment to be emulated for 
that application program. 

2. A data processing system as claimed in the claim 
1, wherein emulation means includes virtual de- 
vice drivers for emulating interfaces between the 
application programs and a system control pro- 
gram for each of the different kinds of system en- 
vironments, interfaces between the application 
programs and device drivers for each of the dif- 
ferent kinds of environments, interfaces between 
the application programs and BIOSs for each of 
different kinds of system environments, and inter- 
faces between the application programs and 
hardware for each of the different kinds of system 
environments. 

3. A data processing system as claimed in claim 1 
or claim 2, wherein the data defining the system 
environment to be emulated is described in a sys- 
tem data area in system memory the virtual de- 
vice drivers emulate the system environment 
based on said data. 
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